<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <script>
        var foo = 1;

        function bar() {
            if (!foo) {
                var foo = 10;
            }
            console.log(foo); // 10
        }
        bar();
        // 相当于下面代码：
        // var foo = 1;
        // function bar() {
        //     var foo; // foo为undefined
        //     if (!foo) {
        //         foo = 10;
        //     }
        //     console.log(foo); // 10
        // }
        // bar();

        //将bar函数中的var改成let的话,输出结果就是1,因为let有块级作用域
        // var foo = 1;

        // function bar() {
        //     if (!foo) {
        //         let foo = 10;
        //     }
        //     console.log(foo); // 1
        // }
        // bar();
    </script>
</body>

</html>